﻿using System;
using System.Data;
using System.Text;
using System.Data.SqlClient;
using XHD.DBUtility;//Please add references
namespace XHD.DAL
{
	/// <summary>
	/// 数据访问类:Crm_Warehouse
	/// </summary>
	public partial class Crm_Warehouse
	{
		public Crm_Warehouse()
		{}
		#region  BasicMethod

		/// <summary>
		/// 得到最大ID
		/// </summary>
		public int GetMaxId()
		{
		return DbHelperSQL.GetMaxID("ID", "Crm_Warehouse"); 
		}

		/// <summary>
		/// 是否存在该记录
		/// </summary>
		public bool Exists(int ID)
		{
			StringBuilder strSql=new StringBuilder();
			strSql.Append("select count(1) from Crm_Warehouse");
			strSql.Append(" where ID=@ID");
			SqlParameter[] parameters = {
					new SqlParameter("@ID", SqlDbType.SmallInt)
			};
			parameters[0].Value = ID;

			return DbHelperSQL.Exists(strSql.ToString(),parameters);
		}


		/// <summary>
		/// 增加一条数据
		/// </summary>
		public int Add(XHD.Model.Crm_Warehouse model)
		{
			StringBuilder strSql=new StringBuilder();
			strSql.Append("insert into Crm_Warehouse(");
			strSql.Append("Name,Address,Lxrid,Lxr,Lxrdh,Remark,InEmpID,InDate,EditEmpID,EditDate,IsDel,DelEmpID,DelDate)");
			strSql.Append(" values (");
			strSql.Append("@Name,@Address,@Lxrid,@Lxr,@Lxrdh,@Remark,@InEmpID,@InDate,@EditEmpID,@EditDate,@IsDel,@DelEmpID,@DelDate)");
			strSql.Append(";select @@IDENTITY");
			SqlParameter[] parameters = {
					new SqlParameter("@Name", SqlDbType.NVarChar,50),
					new SqlParameter("@Address", SqlDbType.NVarChar,500),
					new SqlParameter("@Lxrid", SqlDbType.VarChar,50),
					new SqlParameter("@Lxr", SqlDbType.VarChar,50),
					new SqlParameter("@Lxrdh", SqlDbType.VarChar,50),
					new SqlParameter("@Remark", SqlDbType.NVarChar,500),
					new SqlParameter("@InEmpID", SqlDbType.VarChar,50),
					new SqlParameter("@InDate", SqlDbType.DateTime),
					new SqlParameter("@EditEmpID", SqlDbType.VarChar,50),
					new SqlParameter("@EditDate", SqlDbType.DateTime),
					new SqlParameter("@IsDel", SqlDbType.Char,1),
					new SqlParameter("@DelEmpID", SqlDbType.VarChar,50),
					new SqlParameter("@DelDate", SqlDbType.DateTime)};
			parameters[0].Value = model.Name;
			parameters[1].Value = model.Address;
			parameters[2].Value = model.Lxrid;
			parameters[3].Value = model.Lxr;
			parameters[4].Value = model.Lxrdh;
			parameters[5].Value = model.Remark;
			parameters[6].Value = model.InEmpID;
			parameters[7].Value = model.InDate;
			parameters[8].Value = model.EditEmpID;
			parameters[9].Value = model.EditDate;
			parameters[10].Value = model.IsDel;
			parameters[11].Value = model.DelEmpID;
			parameters[12].Value = model.DelDate;

			object obj = DbHelperSQL.GetSingle(strSql.ToString(),parameters);
			if (obj == null)
			{
				return 0;
			}
			else
			{
				return Convert.ToInt32(obj);
			}
		}
		/// <summary>
		/// 更新一条数据
		/// </summary>
		public bool Update(XHD.Model.Crm_Warehouse model)
		{
			StringBuilder strSql=new StringBuilder();
			strSql.Append("update Crm_Warehouse set ");
			strSql.Append("Name=@Name,");
			strSql.Append("Address=@Address,");
			strSql.Append("Lxrid=@Lxrid,");
			strSql.Append("Lxr=@Lxr,");
			strSql.Append("Lxrdh=@Lxrdh,");
			strSql.Append("Remark=@Remark,");
			strSql.Append("InEmpID=@InEmpID,");
			strSql.Append("InDate=@InDate,");
			strSql.Append("EditEmpID=@EditEmpID,");
			strSql.Append("EditDate=@EditDate,");
			strSql.Append("IsDel=@IsDel,");
			strSql.Append("DelEmpID=@DelEmpID,");
			strSql.Append("DelDate=@DelDate");
			strSql.Append(" where ID=@ID");
			SqlParameter[] parameters = {
					new SqlParameter("@Name", SqlDbType.NVarChar,50),
					new SqlParameter("@Address", SqlDbType.NVarChar,500),
					new SqlParameter("@Lxrid", SqlDbType.VarChar,50),
					new SqlParameter("@Lxr", SqlDbType.VarChar,50),
					new SqlParameter("@Lxrdh", SqlDbType.VarChar,50),
					new SqlParameter("@Remark", SqlDbType.NVarChar,500),
					new SqlParameter("@InEmpID", SqlDbType.VarChar,50),
					new SqlParameter("@InDate", SqlDbType.DateTime),
					new SqlParameter("@EditEmpID", SqlDbType.VarChar,50),
					new SqlParameter("@EditDate", SqlDbType.DateTime),
					new SqlParameter("@IsDel", SqlDbType.Char,1),
					new SqlParameter("@DelEmpID", SqlDbType.VarChar,50),
					new SqlParameter("@DelDate", SqlDbType.DateTime),
					new SqlParameter("@ID", SqlDbType.SmallInt,2)};
			parameters[0].Value = model.Name;
			parameters[1].Value = model.Address;
			parameters[2].Value = model.Lxrid;
			parameters[3].Value = model.Lxr;
			parameters[4].Value = model.Lxrdh;
			parameters[5].Value = model.Remark;
			parameters[6].Value = model.InEmpID;
			parameters[7].Value = model.InDate;
			parameters[8].Value = model.EditEmpID;
			parameters[9].Value = model.EditDate;
			parameters[10].Value = model.IsDel;
			parameters[11].Value = model.DelEmpID;
			parameters[12].Value = model.DelDate;
			parameters[13].Value = model.ID;

			int rows=DbHelperSQL.ExecuteSql(strSql.ToString(),parameters);
			if (rows > 0)
			{
				return true;
			}
			else
			{
				return false;
			}
		}

		/// <summary>
		/// 删除一条数据
		/// </summary>
		public bool Delete(int ID)
		{
			
			StringBuilder strSql=new StringBuilder();
			strSql.Append("delete from Crm_Warehouse ");
			strSql.Append(" where ID=@ID");
			SqlParameter[] parameters = {
					new SqlParameter("@ID", SqlDbType.SmallInt)
			};
			parameters[0].Value = ID;

			int rows=DbHelperSQL.ExecuteSql(strSql.ToString(),parameters);
			if (rows > 0)
			{
				return true;
			}
			else
			{
				return false;
			}
		}
		/// <summary>
		/// 批量删除数据
		/// </summary>
		public bool DeleteList(string IDlist )
		{
			StringBuilder strSql=new StringBuilder();
			strSql.Append("delete from Crm_Warehouse ");
			strSql.Append(" where ID in ("+IDlist + ")  ");
			int rows=DbHelperSQL.ExecuteSql(strSql.ToString());
			if (rows > 0)
			{
				return true;
			}
			else
			{
				return false;
			}
		}


		/// <summary>
		/// 得到一个对象实体
		/// </summary>
		public XHD.Model.Crm_Warehouse GetModel(int ID)
		{
			
			StringBuilder strSql=new StringBuilder();
			strSql.Append("select  top 1 ID,Name,Address,Lxrid,Lxr,Lxrdh,Remark,InEmpID,InDate,EditEmpID,EditDate,IsDel,DelEmpID,DelDate from Crm_Warehouse ");
			strSql.Append(" where ID=@ID");
			SqlParameter[] parameters = {
					new SqlParameter("@ID", SqlDbType.SmallInt)
			};
			parameters[0].Value = ID;

			XHD.Model.Crm_Warehouse model=new XHD.Model.Crm_Warehouse();
			DataSet ds=DbHelperSQL.Query(strSql.ToString(),parameters);
			if(ds.Tables[0].Rows.Count>0)
			{
				return DataRowToModel(ds.Tables[0].Rows[0]);
			}
			else
			{
				return null;
			}
		}


		/// <summary>
		/// 得到一个对象实体
		/// </summary>
		public XHD.Model.Crm_Warehouse DataRowToModel(DataRow row)
		{
			XHD.Model.Crm_Warehouse model=new XHD.Model.Crm_Warehouse();
			if (row != null)
			{
				if(row["ID"]!=null && row["ID"].ToString()!="")
				{
					model.ID=int.Parse(row["ID"].ToString());
				}
				if(row["Name"]!=null)
				{
					model.Name=row["Name"].ToString();
				}
				if(row["Address"]!=null)
				{
					model.Address=row["Address"].ToString();
				}
				if(row["Lxrid"]!=null)
				{
					model.Lxrid=row["Lxrid"].ToString();
				}
				if(row["Lxr"]!=null)
				{
					model.Lxr=row["Lxr"].ToString();
				}
				if(row["Lxrdh"]!=null)
				{
					model.Lxrdh=row["Lxrdh"].ToString();
				}
				if(row["Remark"]!=null)
				{
					model.Remark=row["Remark"].ToString();
				}
				if(row["InEmpID"]!=null)
				{
					model.InEmpID=row["InEmpID"].ToString();
				}
				if(row["InDate"]!=null && row["InDate"].ToString()!="")
				{
					model.InDate=DateTime.Parse(row["InDate"].ToString());
				}
				if(row["EditEmpID"]!=null)
				{
					model.EditEmpID=row["EditEmpID"].ToString();
				}
				if(row["EditDate"]!=null && row["EditDate"].ToString()!="")
				{
					model.EditDate=DateTime.Parse(row["EditDate"].ToString());
				}
				if(row["IsDel"]!=null)
				{
					model.IsDel=row["IsDel"].ToString();
				}
				if(row["DelEmpID"]!=null)
				{
					model.DelEmpID=row["DelEmpID"].ToString();
				}
				if(row["DelDate"]!=null && row["DelDate"].ToString()!="")
				{
					model.DelDate=DateTime.Parse(row["DelDate"].ToString());
				}
			}
			return model;
		}

		/// <summary>
		/// 获得数据列表
		/// </summary>
		public DataSet GetList(string strWhere)
		{
			StringBuilder strSql=new StringBuilder();
			strSql.Append("select ID,Name,Address,Lxrid,Lxr,Lxrdh,Remark,InEmpID,InDate,EditEmpID,EditDate,IsDel,DelEmpID,DelDate ");
			strSql.Append(" FROM Crm_Warehouse ");
			if(strWhere.Trim()!="")
			{
				strSql.Append(" where "+strWhere);
			}
			return DbHelperSQL.Query(strSql.ToString());
		}

		/// <summary>
		/// 获得前几行数据
		/// </summary>
		public DataSet GetList(int Top,string strWhere,string filedOrder)
		{
			StringBuilder strSql=new StringBuilder();
			strSql.Append("select ");
			if(Top>0)
			{
				strSql.Append(" top "+Top.ToString());
			}
			strSql.Append(" ID,Name,Address,Lxrid,Lxr,Lxrdh,Remark,InEmpID,InDate,EditEmpID,EditDate,IsDel,DelEmpID,DelDate ");
			strSql.Append(" FROM Crm_Warehouse ");
			if(strWhere.Trim()!="")
			{
				strSql.Append(" where "+strWhere);
			}
			strSql.Append(" order by " + filedOrder);
			return DbHelperSQL.Query(strSql.ToString());
		}

		/// <summary>
		/// 获取记录总数
		/// </summary>
		public int GetRecordCount(string strWhere)
		{
			StringBuilder strSql=new StringBuilder();
			strSql.Append("select count(1) FROM Crm_Warehouse ");
			if(strWhere.Trim()!="")
			{
				strSql.Append(" where "+strWhere);
			}
			object obj = DbHelperSQL.GetSingle(strSql.ToString());
			if (obj == null)
			{
				return 0;
			}
			else
			{
				return Convert.ToInt32(obj);
			}
		}
		/// <summary>
		/// 分页获取数据列表
		/// </summary>
		public DataSet GetListByPage(string strWhere, string orderby, int startIndex, int endIndex)
		{
			StringBuilder strSql=new StringBuilder();
			strSql.Append("SELECT * FROM ( ");
			strSql.Append(" SELECT ROW_NUMBER() OVER (");
			if (!string.IsNullOrEmpty(orderby.Trim()))
			{
				strSql.Append("order by T." + orderby );
			}
			else
			{
				strSql.Append("order by T.ID desc");
			}
			strSql.Append(")AS Row, T.*  from Crm_Warehouse T ");
			if (!string.IsNullOrEmpty(strWhere.Trim()))
			{
				strSql.Append(" WHERE " + strWhere);
			}
			strSql.Append(" ) TT");
			strSql.AppendFormat(" WHERE TT.Row between {0} and {1}", startIndex, endIndex);
			return DbHelperSQL.Query(strSql.ToString());
		}

        /*
		/// <summary>
		/// 分页获取数据列表
		/// </summary>
		public DataSet GetList(int PageSize,int PageIndex,string strWhere)
		{
			SqlParameter[] parameters = {
					new SqlParameter("@tblName", SqlDbType.VarChar, 255),
					new SqlParameter("@fldName", SqlDbType.VarChar, 255),
					new SqlParameter("@PageSize", SqlDbType.Int),
					new SqlParameter("@PageIndex", SqlDbType.Int),
					new SqlParameter("@IsReCount", SqlDbType.Bit),
					new SqlParameter("@OrderType", SqlDbType.Bit),
					new SqlParameter("@strWhere", SqlDbType.VarChar,1000),
					};
			parameters[0].Value = "Crm_Warehouse";
			parameters[1].Value = "ID";
			parameters[2].Value = PageSize;
			parameters[3].Value = PageIndex;
			parameters[4].Value = 0;
			parameters[5].Value = 0;
			parameters[6].Value = strWhere;	
			return DbHelperSQL.RunProcedure("UP_GetRecordByPage",parameters,"ds");
		}*/

        #endregion  BasicMethod
        #region  ExtensionMethod
        /// <summary>
        /// 分页获取数据列表
        /// </summary>
        public DataSet GetList(int PageSize, int PageIndex, string strWhere, string filedOrder, out string Total)
        {
            StringBuilder strSql_inner = new StringBuilder();
            StringBuilder strSql_grid = new StringBuilder();
            StringBuilder strSql_total = new StringBuilder();

            //联合数据
            strSql_inner.Append("  (SELECT * ");
            strSql_inner.Append($"        ,ROW_NUMBER() OVER(Order by {filedOrder}) AS n FROM ");
            strSql_inner.Append(" Crm_Warehouse w2 ");
            if (strWhere.Trim() != "")
            {
                strSql_inner.Append(" WHERE " + strWhere);
            }
            strSql_inner.Append(") W3");

            //Total数据%
            strSql_total.Append(" SELECT COUNT(ID) FROM ");
            strSql_total.Append(strSql_inner.ToString());

            //grid数据
            strSql_grid.Append(" SELECT * FROM ");
            strSql_grid.Append(strSql_inner.ToString());
            strSql_grid.Append(" WHERE n BETWEEN " + PageSize * (PageIndex - 1) + " AND " + PageSize * PageIndex);

            Total = DbHelperSQL.Query(strSql_total.ToString()).Tables[0].Rows[0][0].ToString();
            return DbHelperSQL.Query(strSql_grid.ToString());
        }

        #endregion  ExtensionMethod
    }
}

